// page/login/login.js
/*
登录说明
  1.收集表单单项数据
  2.前端验证
    1)验证用户信息是否合法
    2)前端验证不通过 就提示用户内容不合法 不需要发请求进行后端验证
    3)前端验证通过 发请求(账号 密码)进行后端验证
  3.后端验证
    1)验证用户名是否存在
    2)如果该用户不存在,直接返回登录失败(该用户不存在)
    3)该用户存在.需要验证密码是否正确
    4)密码不正确,返回给前端,并提示密码不正确
    5)密码正确 返回登录成功的数据
*/
import request from '../../utils/request'
Page({

  /**
   * 页面的初始数据
   */
  data: {
    //初始化数据
    password: '',
    phone: ''

  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {

  },
  //收集表单数据 用户信息
  handleInput(event) {
    //let type=event.currentTarget.id //传参两种方式 第一种
    let type = event.currentTarget.dataset.type //传参两种方式 第2种
    this.setData({
      [type]: event.detail.value
    })
  },
  //登录的回调
 async login() {
    //1.获取表单数据
    let { phone, password } = this.data
    //2.前端验证
    /*
    手机号验证
      1.手机号码为空
      2.手机号格式不正确
      3.手机号格式正确 验证通过     
    */
    // 1.手机号码为空
    if (!phone) {
      wx.showToast({
        title: '手机号不能为空',
        icon: 'none'
      })
      return
    }
    // 2.手机号格式不正确
    let phoneReg = /^1(3|4|5|6|7|8|9)\d{9}$/
    if (!phoneReg.test(phone)) {
      wx.showToast({
        title: '手机号格式错误',
        icon: 'none'
      })
      return
    }
    //3.验证密码
    if (!password) {
      wx.showToast({
        title: '密码不对',
        icon: 'none'
      })
      return
    }
    //4后端验证 发请求 看接口文档
      let result= await request('/login/cellphone',{password,phone,isLogin: true})
      //状态码有200 502 400
      if(result.code===200){
        //登录成功
        wx.showToast({
          title: '登录成功',
          icon: 'none'
        })
        //登录成功干啥
        wx.setStorageSync('userInfo',result.profile)
        //跳转至个人用户中心 wx.navigateTo不能跳转到tabBar页面 个人中心属于tabBar页面 需要用到wx.reLaunch
        wx.reLaunch({
          url:"/pages/personal/personal"
        })
      }else if(result.code===502){
        wx.showToast({
          title: '密码错误',
          icon: 'none'
        })
      }else if(result.code===400){
        wx.showToast({
          title: '手机号错误',
          icon: 'none'
        })
      }else{
        //登录失败
        wx.showToast({
          title: '登录失败',
          icon: 'none'
        })
      }

  },
  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady: function () {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow: function () {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide: function () {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload: function () {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh: function () {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom: function () {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage: function () {

  }
})